Home Source Code

Introduction

The double pendulum, or chaotic pendulum, is a system that comprises of a pendulum attached to the end of another pendulum. This system, as I will derive below, is governed by a set of coupled non-linear ordinary differential equations. Beyond small angles, in which case the system can be described as a coupled oscillator, the system cannot be solved analytically and numerical methods must be employed. The system exhibits properties of non-linear systems such as chaotic motion and sensitivity to initial conditions.

You can start and stop the simulation with the start/pause button. To adjust the parameters of the system, the time rate, time step, and path settings, click the settings button to open up the settings menu. You can also drag the pendulum bobs to modify their angles. Choosing different presets from the dropdown initializes the system with a set of initial conditions. The reset button resets the system to whatever initial conditions are selected from the dropdown. Clicking on the graphs tab gives you options for graphing parameters to create phase-portraits.

Equations of Motion

The double pendulum consists of a mass m₁ suspended by a massless rod of length L₁, from a fixed pivot, and a second mass m₂ suspended by a massless rod of length L₂ from m₁. The equations of motion for the system will be derived using the Lagrangian formalism. We will use θ₁, the angle of m₁ relative to it's vertical, and θ₂, the angle of m₂ relative to it's vertical, as our generalized coordinates. The resulting kinetic and potential energy of the system is:

T=12ML12θ1˙2+12m2L22θ2˙2+m2L1L2θ1˙θ2˙cosΔθ U=MgL1cosθ1m2gL2cosθ2
where I have defined M = m₁ + m₂ and Δθ = θ₁ - θ₂. The resulting Lagrangian is just T - U:
L=12ML12θ1˙2+12m2L22θ2˙2+m2L1L2θ1˙θ2˙cosΔθ+MgL1cosθ1+m2gL2cosθ2
We can then apply the Euler-Lagrange equation to both θ₁ and θ₂:
Lθ1=ddt(Lθ1˙)θ¨1+g1(θ1,θ2)θ¨2=f1(θ1,θ2,θ˙1,θ˙2) Lθ2=ddt(Lθ2˙)θ¨2+g2(θ1,θ2)θ¨1=f2(θ1,θ2,θ˙1,θ˙2)
where for readability I have defined functions:
g1=m2ML2L1cosΔθ,f1=m2ML2L1θ˙22sinΔθgL1sinθ1 g2=L1L2cosΔθ,f2=L1L2θ˙12sinΔθgL2sinθ2
We can express this system of equations in matrix form:
Gθ¨=(1g1g21)(θ¨1θ¨2)=(f1f2)
To solve we note that:
det(G)=1g1g2=1m2Mcos2Δθ1m2M>0
Thus, G is a non-singular matrix and has an inverse. We can apply G inverse to both sides to solve:
θ¨=G1f=1det(G)(1g1g21)(f1f2)=11g1g2(f1g1f2g2f1+f2)=(h1(θ1,θ2,θ˙1,θ˙2)h2(θ1,θ2,θ˙1,θ˙2))
where again for readability I have defined functions:
h1=f1g1f21g1g2 h2=g2f1+f21g1g2
Finally, to get it into a form useful for numerical integration we turn it into a set of first-order differential equations by defining ωᵢ = θᵢ':
ddt(θ1θ2ω1ω2)=(ω1ω2h1h2)
This is a set of coupled non-linear ordinary differential equations and cannot be solved analytically. However, we can use this form for numerical integration. In my simulation I use the fourth-order Runge-Kutta method (RK4).

Numerical Integration Method

This simulation uses the fourth-order Runge-Kutta (RK4) method for numerically solving the system of first-order non-linear ordinary differential equations presented above. Since the double pendulum is an autonomous system the initial value problem can be specified as follows:

dydt=f(y),y(t0)=y0
where:
y=(θ1θ2ω1ω2),f=(ω1ω2h1h2)
The Runge-Kutta method takes this IVP and a time step, h, and determines the next state based on the previous state and a successive weighted average of slopes:
yn+1=yn+h6(k1+2k2+2k3+k4) tn+1=tn+h
where the slopes are:
k1=f(yn) k2=f(yn+h2k1) k3=f(yn+h2k2) k4=f(yn+hk3)